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Detailed Action 

This office action is in response to the correspondence received on March 7, 2005. 

Claim Rejections • 35 USC § 103 

The following is a quotation of 35 U.S.C. 103(a) which forms the basis for all 
obviousness rejections set forth in this Office action: 

(a) A patent may not be obtained though the invention is not identically disclosed or described as set 
forth in section 102 of this title, if the differences between the subject matter sought to be patented and 
the prior art are such that the subject matter as a whole would have been obvious at the time the 
invention was made to a person having ordinary skill in the art to which said subject matter pertains. 
Patentability shall not be negatived by the manner in which the invention was made. 

Claims 21-50 are rejected under 35 U.S.C. 103(a) as being unpatentable over 

Doyle et al (US Pat No: 5838906) in view of Held et al (US Pat No: 5802367), 

hereafter referred to as Doyle and Held, respectively. 

1 . With regards to claim 21 , Doyle teaches through Held, the method for accessing 
multiple types of electronic content, comprising: receiving a request for a 
computer program to process an input to obtain an output comprising a type of 
content that is unl<nown to the computer program, wherein a service manager 
connects the computer program to at least one service container to process the 
input to obtain the output; selecting at least one segment of computer code from 
a plurality of segments of computer code that will enable the computer program 
to process the input, when the at least one segment of computer code is 
executed along with the computer program, to provide the output comprising the 
type of content that is unknown to the computer program, the at least one 
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segment of computer code being selected without reference to any embedded 
link by said computer program; and executing the at least one segment of 
computer code along with the computer program to process the input and obtain 
the output comprising the type of content that is unknown to the computer 
program, wherein the plurality of segments of computer code and the at least one 
segment of computer code are not executable as an independent computer 
program 

(Doyle teaches a design that features a "list of applications," (column 15, 
line 14, Doyle). The list of applications allows an application to be selected to run 
along with the original program to provide ari output from an input that the 
original program alone would be unable to provide as claimed. In addition, since 
the list of applications is initiated by the system, there must exist a service 
manager as claimed. However, such means are not expressly stated within 
Doyle's design. 

Held discloses a design allowing a second program or process to be 
called to assist a first program to perform a desired task on data (column 3, line 
65 - column 4, line 57, Held). Within the disclosure, Held states the existence of 
a service control manager (equivalent to the service manager) (column 4, line 16, 
Held). In addition. Held teaches how a surrogate process can be called from a 
first program without reference to an embedded link. 

Both Doyle and Held teach systems allowing one program to call upon 
another program to perform an operation on a piece of data. Hence, it would 
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have been obvious to one skilled in the art, during the time of the invention, to 
have combined the teachings of Doyle with those of Held, to provide a method 
for transparently executing code using a surrogate process (column 3, line 67 - 
column 4, line 1 , Held)). 

2. With regards to claim 22, Doyle teaches through Held, a method wherein selecting 
at least one segment of computer code comprises selecting at least two 
segments of computer code from the plurality of segments of computer code 
whose combined functionality will enable the computer program to process the 
input, when the at least two segments of computer code are executed along with 
the computer program, to provide the output comprising the type of content that 
is unknown to the computer program, the at least two segments of computer 
code being selected based upon the functionality that each provides 

(Doyle teaches a design that features a "list of applications," (column 1 5, 
line 14, Doyle). The list of applications allows an application to be selected to run 
along with the original program to provide ah output from an input that the 
original program alone would be unable to provide, as claimed. No limitation is 
given as to how many applications may be selected to run together, hence two or 
more may be selected as claimed. In addition, since the list of applications is 
initiated by the system, there must exist a service manager as claimed. 
However, such means are not expressly stated within Doyle's design. 
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Held discloses a design allowing a second program or process to be 
called to assist a first program to perform a desired task on data (column 3, line 
65 - column 4, line 57, Held). Within the disclosure, Held states the existence of 
a service control manager (equivalent to the service manager) (column 4, line 16, 
Held). In addition, Held teaches how a surrogate process can be called from a 
first program without reference to an jembedded link. Plus, Held teaches how 
processes are selected based on how well it will function (for instance with 
regards to compatibility with the first program) (column 7, line 58 - column 8, line 
12, Held). 

Both Doyle and Held teach systems allowing one program to call upon 
another program to perform an operation on a piece of data. Hence, it would 
have been obvious to one skilled in the art, during the time of the invention, to 
have combined the teachings of Doyle with those of Held, to provide a method 
for transparently executing code using a surrogate process (column 3, line 67 - 
column 4, line 1, Held)). 

3. With regards to claim 23, Doyle teaches through Held, the method further 
comprising configuring the at least two segments of computer code to be 
executed along with the computer program in a particular order to provide a 
desired processing of the input 

(Doyle teaches a design that features a "list of applications," (column 15, 
line 14, Doyle). The list of applications allows an application to be selected to run 
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along with the original program to provide an output from an input that the 
original program alone would be unable to provide, as claimed. No limitation is 
given as to how many applications may be selected to run together; hence two or 
more may be selected as claimed. Whenever multiple applications run together 
to produce a single output, it is inherent that they will perform in order as claimed. 
In addition, since the list of applications is initiated by the system, there must 
exist a service manager as claimed. However, such means are not expressly 
stated within Doyle's design. 

Held discloses a design allowing a second program or process to be 
called to assist a first program to perform a desired task on data (column 3, line 
65 - column 4, line 57, Held). Within the disclosure. Held states the existence of 
a service control manager (equivalent to the service manager) (column 4, line 16, 
Held). In addition, Held teaches how a surrogate process can be called from a 
first program without reference to an embedded link. 

Both Doyle and Held teach systems allowing one program to call upon 
another program to perform an operation on a piece of data. Hence, it would 
have been obvious to one skilled in the art, during the time of the Invention, to 
have combined the teachings of Doyle with those of Held, to provide a method 
for transparently executing code using a surrogate process (column 3, line 67 - 
column 4, line 1, Held)). 
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4. With regards to claim 24, Doyle teaches through Held, a method further 
comprising configuring the at least two segments of computer code into a 
master-slave relationship that causes the execution of one of the at least two 
segments of computer code to be dependent on the execution of another of the 
at least two segments of computer code 

(Doyle discloses how applications can be started as child processes 
(column 15, line 22, Doyle). When a child process exists, a parent process must 
exist. This parent-child relationship is equivalent to a master-slave relationship. 
In addition, since the list of applications is initiated by the system, there must 
exist a service manager as claimed. However, such means are not expressly 
stated within Doyle's design. 

Held discloses a design allowing a second program or process to be 
called to assist a first program to perform a desired task on data (column 3, line 
65 - column 4, line 57, Held). Within the disclosure. Held states the existence of 
a service control manager (equivalent to the service manager) (column 4, line 16, 
Held). In addition, Held teaches how a surrogate process can be called from a 
first program without reference to an embedded link. 

Both Doyle and Held teach systems allowing one program to call upon 
another program to perform an operation on a piece of data. Hence, it would 
have been obvious to one skilled in the art, during the time of the invention, to 
have combined the teachings of Doyle with those of Held, to provide a method 
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for transparently executing code using a surrogate process (column 3, line 67 - 
column 4, line 1, Held)). 

5. With regards to claim 25, Doyle teaches through Held, a method wherein 

executing the at least one segment of computer code comprises integrating the 
at least one segment of computer code into the computer program and executing 
the computer program to process the input and obtain the output comprising the 
type of content that is unknown to the computer program 

(Doyle teaches a design that features a "list of applications," (column 15, 
line 14, Doyle). This list of applications allows an application to be selected to 
run along with the original program to provide an output from an input that the 
original program alone would be unable to provide. When an application runs 
along with the original program, Doyle states that it is "embedded" (column 6,, 
lines 58-59, Doyle). Embedded is equivalent to the claimed integrated. In 
addition, since the list of applications is initiated by the system, there must exist a 
service manager as claimed. However, such means are not expressly stated 
within Doyle's design. 

Held discloses a design allowing a second program or process to be 
called to assist a first program to perform a desired task on data (column 3, line 
65 - column 4, line 57, Held). Within the disclosure. Held states the existence of 
a service control manager (equivalent to the service manager) (column 4, line 16, 
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Held). In addition, Held teaches how a surrogate process can be called from a 

first program without reference to an embedded link 

Both Doyle and Held teach systems allowing one program to call upon 
another program to perform an operation on a piece of data. Hence, it would have 
been obvious to one skilled in the art, during the time of the invention, to have 
combined the teachings of Doyle with those of Held, to provide a method for 
transparently executing code using a surrogate process (column 3, line 67 - 
column 4, line 1, Held)). 

6. With regards to claim 26, Doyle teaches through Held, a method wherein receiving 
a request for a computer program to process an input comprises receiving a 
command to translate a word from a first language to a second language 

(Doyle discloses a design that features a "list of applications," (column 15, 
line 14, Doyle). These applications are able to run along with an original program 
to provide an output from an input the original program is unable to produce 
alone. No limitation is placed on the type of programs available, hence 
translation programs are usable within the scope of the design. In addition, since 
the list of applications is initiated by the system, there must exist a service 
manager as claimed. However, such means are not expressly stated within 
Doyle's design. 

Held discloses a design allowing a second program or process to be 
called to assist a first program to perform a desired task on data (column 3, line 



Application/Control Number: 09/606,641 Page 10 

Art Unit: 2145 

65 - column 4, line 57, Held). Within the disclosure. Held states the existence of 
a service control manager (equivalent to the service manager) (column 4, line 16, 
Held). In addition, Held teaches how a surrogate process can be called from a 
first program without reference to an embedded link. Plus, no limitation is placed 
on the type of functionality the second (surrogate) program or process can 
provide. 

Both Doyle and Held teach systems allowing one program to call upon 
another program to perform an operation on a piece of data. Hence, it would 
have been obvious to one skilled in the art, during the time of the invention, to 
have combined the teachings of Doyle with those of Held, to provide a method 
for transparently executing code using a surrogate process (column 3, line 67 - 
column 4, line 1, Held)). 

7. With regards to claim 27, Doyle teaches through Held, a method wherein receiving 
a request for a computer program to process an input comprises receiving a 
command to convert a number from a first number format to a second number 
format 

(Doyle discloses a design that features a "list of applications," (column 15, 
line 14, Doyle). These applications are able to run along with an original program 
to provide an output from an input the original program is unable to produce 
alone. No limitation is placed on the type of programs available, hence number 
conversion programs are usable within the scope of the design. In addition. 
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since the list of applications is initiated by the system, there must exist a service 
manager as claimed. However, such means are not expressly stated within 
Doyle's design. 

Held discloses a design allowing a second program or process to be 
called to assist a first program to perform a desired task on data (column 3, line 
65 - column 4, line 57, Held). Within the disclosure. Held states the existence of 
a service control manager (equivalent to the.service manager) (column 4, line 16, 
Held). In addition, Held teaches how a surrogate process can be called from a 
first program without reference to an embedded link. Plus, no limitation is placed 
on the type of functionality the second (surrogate) program or process can 
provide. 

Both Doyle and Held teach systems allowing one program to call upon 
another program to perform an operation on a piece of data. Hence, it would 
have been obvious to one skilled in the art, during the time of the invention, to 
have combined the teachings of Doyle with those of Held, to provide a method 
for transparently executing code using a surrogate process (column 3, line 67 - 
column 4, line 1, Held)). 

8. With regards to claim 28, Doyle teaches through Held, the method wherein 
receiving a request for a computer program to process an input comprises 
receiving a command to convert a text object from a first text format to a second 
text format 
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(Doyle discloses a design that features a "list of applications," (column 15, 
line 14, Doyle). These applications are able to run along with an original program 
to provide an output from an input the original program is unable to produce 
alone. No limitation is placed on the type of programs available, hence text 
format conversion programs are usable within the scope of the design. In 
addition, since the list of applications is initiated by the system, there must exist a 
service manager as claimed. However, such means are not expressly stated 
within Doyle's design. 

Held discloses a design allowing a second program or process to be 
called to assist a first program to perform a desired task on data (column 3, line 
65 - column 4, line 57, Held). Within the disclosure. Held states the existence of 
a service control manager (equivalent to the service manager) (column 4, line 16, 
Held). In addition. Held teaches how a surrogate process can be called from a 
first program without reference to an embedded link. Plus, no limitation is placed 
on the type of functionality the second (surrogate) program or process can 
provide. 

Both Doyle and Held teach systems allowing one program to call upon 
another program to perform an operation on a piece of data. Hence, it would 
have been obvious to one skilled in the art, during the time of the invention, to 
have combined the teachings of Doyle with those of Held, to provide a method 
for transparently executing code using a surrogate process (column 3, line 67 - 
column 4, line 1, Held)). 
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9. With regards to claim 29, Doyle teaches through Held, a method wherein receiving 
a request for a computer program to process an input comprises receiving a 
command to convert a graphical object from a first graphical format to a second 
graphical format 

(Doyle discloses a design that features a "list of applications," (column 15, 
line 14, Doyle). These applications are able to run along with an original program 
to provide an output from an input the original program is unable to produce 
alone. No limitation is placed on the type of programs available; hence graphical 
format conversion programs are usable within the scope of the design. In 
addition, since the list of applications is initiated by the system, there must exist a 
service manager as claimed! However, such means are not expressly stated 
within Doyle's design. 

Held discloses a design allowing a second program or process to be 
called to assist a first program to perform a desired task on data (column 3, line 
65 - column 4, line 57, Held). Within the disclosure, Held states the existence of 
a service control manager (equivalent to the service manager) (column 4, line 16, 
Held). In addition. Held teaches how a surrogate process can be called from a 
first program without reference to an embedded link. Plus, no limitation is placed 
on the type of functionality the second (surrogate) program or process can 
provide. 
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Both Doyle and Held teach systems allowing one program to call upon 
another program to perform an operation on a piece of data. Hence, it would 
have been obvious to one skilled in the art, during the time of the invention, to 
have combined the teachings of Doyle with those of Held, to provide a method 
for transparently executing code using a surrogate process (column 3, line 67 - 
column 4, line 1, Held)). 

10. With regards to claim 30, Doyle teaches through Held, a computer system for 
accessing multiple types of electronic content, comprising: a processing unit; a 
memory in communication with the processing unit; and a computer program 
stored in the memory that provides instructions to the processing unit, wherein 
the processing unit is responsive to the instructions, operable for: identifying a 
plurality of segments of computer code that can be executed along with the 
computer program by the processing unit in response to the instructions; 
selecting, in response to an input command to access at least one type of 
content that the computer program is not configured to access, at least one 
segment of computer code from the plurality of segments of computer code that 
can be executed along with the computer program by the processing unit, in 
response to the instructions, to access the at least one type of content that the 
computer program is not configured to access, wherein a service manager 
connects the computer program to at least one service container in response to 
the input command, wherein said computer program is not directed to the 
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plurality of segments of computer code by any embedded link referenced by said 
computer program; and executing the at least one segment of computer code 
along with the computer program to access the at least one type of content that 
the computer program is not configured to access; wherein the plurality of 
segments of computer code and the at least one segment of computer code are 
not executable as an independent computer program 

(Doyle teaches a design that features a "list of applications," (column 15, 
line 14, Doyle). The list of applications allows an application to be selected to run 
along with the original program to provide an output from an input that the 
original program alone would be unable to provide as claimed. In addition, since 
the list of applications is initiated by the system, there must exist a service 
manager as claimed. However, such means are not expressly stated within 
Doyle's design. 

Held discloses a design allowing a second program or process to be 
called to assist a first program to perform a desired task on data (column 3, line 
65 - column 4, line 57, Held). Within the disclosure, Held states the existence of 
a service control manager (equivalent to the service manager) (column 4, line 16, 
Held). In addition, Held teaches how a surrogate process can be called from a 
first program without reference to an embedded link. 

Both Doyle and Held teach systems allowing one program to call upon 
another program to perform an operation on a piece of data. Hence, it would 
have been obvious to one skilled in the art, during the time of the invention, to 
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have combined the teachings of Doyle with those of Held, to provide a method 
for transparently executing code using a surrogate process (column 3, line 67 - 
column 4, line 1, Held)). 

1 1 .With regards to claim 31 , Doyle teaches through Held a computer system 
wherein the processing unit, responsive to the instructions, is further operable 
for: arranging in the memory the at least one segment of computer code and a 
data, comprising the at least one type of content that the computer program is 
not configured to access, into a function-content group; and interfacing the 
function-content group to the computer program to enable the computer program 
to access the at least one type of content that the computer program is not 
configured to access 

(Doyle teaches a design that features a "list of applications," (column 15, 
line 14, Doyle). The list of applications allows an application to be selected to run 
along with the original program to provide an output from an input that the 
original program alone would be unable to provide, as claimed. No limitations 
are placed as to the number of programs that may be run together. In addition, 
since the list of applications is initiated by the system, there must exist a service 
manager as claimed. However, such means are not expressly stated within 
Doyle's design. 

Held discloses a design allowing a second program or process to be 
called to assist a first program to perform a desired task on data (column 3, line 
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65 - column 4, line 57, Held). Within the disclosure. Held states the existence of 
a service control manager (equivalent to the service manager) (column 4, line 16, 
Held). In addition, Held teaches how a surrogate process can be called from a 
first program without reference to an embedded link. 

Both Doyle and Held teach systems allowing one program to call upon 
another program to perform an operation on a piece of data. Hence, it would 
have been obvious to one skilled in the art, during the time of the invention, to 
have combined the teachings of Doyle with those of Held, to provide a method 
for transparently executing code using a surrogate process (column 3, line 67 - 
column 4, line 1, Held)). 

12. With regards to claim 32, Doyle teaches through Held, the computer system 
wherein the processing unit, responsive to the instructions, is operable for 
identifying a plurality of segments of computer code by: locating at least two 
segments of computer code from the plurality of segments of computer code that 
each comprise a portion of computer code that indicates they can be executed by 
the processing unit along with the computer program; and generating a list in the 
memory comprising an identifier for each of the at least two segments of 
computer code that indicates that the at least two segments of computer code 
are available to be executed by the processing unit along with the computer 
program 
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(Doyle teaches a design that features a "list of applications," (column 15, 
line 14, Doyle). The list of applications allows an application to be selected to run 
along with the original program to provide an output from an input that the 
original program alone would be unable to provide, as claimed. No limitation is 
given as to how many applications may be selected to run together; hence two or 
more may be selected as claimed. In addition, since the list of applications is 
initiated by the system, there must exist a service manager as claimed. 
However, such means are not expressly stated within Doyle's design. 

Held discloses a design allowing a second program or process to be 
called to assist a first program to perform a desired task on data (column 3, line 
65 - column 4, line 57, Held). Within the disclosure, Held states the existence of 
a service control manager (equivalent to the service manager) (column 4, line 16, 
Held). In addition, Held teaches how a surrogate process can be called from a 
first program without reference to an embedded link. Plus, Held discloses that 
multiple classes can be implemented by the same module (hence multiple 
behaviors/function/services can be made available and selected) (column 5, lines 
30-49, Held). 

Both Doyle and Held teach systems allowing one program to call upon 
another program to perform an operation on a piece of data. Hence, it would 
have been obvious to one skilled in the art, during the time of the invention, to 
have combined the teachings of Doyle with those of Held, to provide a method 
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for transparently executing code using a surrogate process (column 3, line 67 - 
column 4, line 1, Held)). 

13. With regards to claim 33, Doyle teaches through Held, a computer system 
wherein the processing unit, responsive to the instructions, is operable for 
selecting at least one segment of computer code by selecting at least two 
segments of computer code from the plurality of segments of computer code 
whose combined functionality will allow the computer program to access the at 
least one type of content that the computer program is not configured to access 
when the at least two segments of computer code are executed by the 
processing unit along with the computer program 

(Doyle teaches a design that features a list of applications," (column 15, 
line 14, Doyle). The list of applications allows an application to be selected to run 
along with the original program to provide an output from an input that the 
original program alone would be unable to provide, as claimed. No limitation is 
given as to how many applications may be selected to run together, hence two or 
more may be selected as claimed. In addition, since the list of applications is 
initiated by the system, there must exist a service managei^ as claimed. 
However, such means are not expressly stated within Doyle's design. 

Held discloses a design allowing a second program or process to be 
called to assist a first program to perform a desired task on data (column 3, line 
65 - column 4, line 57, Held). Within the disclosure. Held states the existence of 
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a service control manager (equivalent to the service manager) (column 4, line 16, 
Held). In addition, Held teaches how a surrogate process can be called from a 
first program without reference to an embedded link. Plus, Held discloses that 
multiple classes can be implemented by the same module (hence multiple 
behaviors/function/services can be made available and selected) (column 5, lines 
30-49, Held). 

Both Doyle and Held teach systems allowing one program to call upon 
another program to perform an operation on a piece of data. Hence, it would 
have been obvious to one skilled in the art, during the time of the invention, to 
have combined the teachings of Doyle with those of Held, to provide a method 
for transparently executing code using a surrogate process (column 3, line 67 - 
column 4, line 1, Held)). 

14. With regards to claim 34, Doyle teaches through Held, the computer system 
wherein the processing unit, responsive to the instructions, is further operable for 
configuring the at least two segments of computer code to be executed by the 
processing unit along with the computer program in a particular order to allow the 
computer program to access the at least one type of content that the computer 
program is not configured to access 

(Doyle teaches a design that features a "list of applications," (column 15, 
line 14, Doyle). The list of applications allows an application to be selected to run 
along with the original program to provide an output from an input that the 
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original program alone would be unable to provide, as claimed. No limitation is 
given as to how many applications may be selected to run together, hence two or 
more may be selected as claimed. Whenever multiple applications run together 
to produce a single output, it is inherent that they will perform in order as claimed. 
In addition, since the list of applications is initiated by the system, there must 
exist a service manager as claimed. However, such means are not expressly 
stated within Doyle's design. 

Held discloses a design allowing a second program or process to be 
called to assist a first program to perform a desired task on data (column 3, line 
65 - column 4, line 57, Held). Within the disclosure, Held states the existence of 
a service control manager (equivalent to the service manager) (column 4, line 16, 
Held). In addition. Held teaches how a surrogate process can be called from a 
first program without reference to an embedded link. Plus, Held discloses that 
multiple classes can be implemented by the same module (hence multiple 
behaviors/function/services can be made available and selected) (column 5, lines 
30-49, Held). 

Both Doyle and Held teach systems allowing one program to call upon 
another program to perform an operation on a piece of data. Hence, it would 
have been obvious to one skilled in the art, during the time of the invention, to 
have combined the teachings of Doyle with those of Held, to provide a method 
for transparently executing code using a surrogate process (column 3, line 67 - 
column 4, line 1, Held)), 
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15. With regards to claim 35, Doyle teaches through Held, the computer system, 
wherein the processing unit, responsive to the instructions, is further operable for 
configuring the at least two segments of computer code into a master-slave 
relationship that causes the execution of one of the at least two segments of 
computer code to be dependent on the execution of another of the at least two 
segments of computer code 

(Doyle discloses how applications can be started as child processes 
(column 15, line 22, Doyle). When a child process exists, a parent process must 
exist. This parent-child relationship is equivalent to a master-slave relationship. 
In addition, since the list of applications is initiated by the system, there must 
exist a service manager as claimed. However, such means are not expressly 
stated within Doyle's design. 

Held discloses a design allowing a second program or process to be 
called to assist a first program to perform a desired task on data (column 3, line 
65 - column 4, line 57, Held). Within the disclosure, Held states the existence of 
a service control manager (equivalent to the service manager) (column 4, line 16, 
Held). In addition, Held teaches how a surrogate process can be called from a 
first program without reference to an embedded link. 

Both Doyle and Held teach systems allowing one program to call upon 
another program to perform an operation on a piece of data. Hence, it would 
have been obvious to one skilled in the art, during the time of the invention, to 
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have combined the teachings of Doyle with those of Held, to provide a method 
for transparently executing code using a surrogate process (column 3, line 67 - 
column 4, line 1, Held)). 

16. With regards to claim 36, Doyle teaches through Held, a computer-readable 
medium having computer-executable instructions for accessing multiple types of 
electronic content, comprising: logic for creating a list that comprises information 
about a plurality of segments of computer code that can be executed along with a 
computer program; logic for choosing at least one segment of computer code 
from the plurality of segments of computer code, based on the information in the 
list, that can be executed along with the computer program to process a type of 
data that the computer program is not designed to process, wherein said 
computer program is not directed to the at least one segment of computer code 
by any embedded link referenced by said computer program; logic to execute the 
at least one segment of computer code along with the computer program in 
response to an input to provide an output of the type of data that the computer 
program is not designed to process, wherein a service manager connects the 
computer program to at least one service container in response to the input; and 
wherein the plurality of segments of computer code and the at least one segment 
of computer code are not executable as an independent computer program 

(Doyle teaches a design that features a "list of applications," (column 15, 
line 14, Doyle). The list of applications allows an application to be selected to run 
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along with the original program to provide an output from an input that the 
original program alone would be unable to provide as claimed. In addition, since 
the list of applications is initiated by the system, there must exist a service 
manager as claimed. However, such means are not expressly stated within 
Doyle's design. 

Held discloses a design allowing a second program or process to be 
called to assist a first program to perform a desired task on data (column 3, line 
65 - column 4, line 57, Held). Within the disclosure, Held states the existence of 
a service control manager (equivalent to the service manager) (column 4, line 16, 
Held). In addition. Held teaches how a surrogate process can be called from a 
first program without reference to an embedded link. 

Both Doyle and Held teach systems allowing one program to call upon 
another program to perform an operation on a piece of data. Hence, it would 
have been obvious to one skilled in the art, during the time of the invention, to 
have combined the teachings of Doyle with those of Held, to provide a method 
for transparently executing code using a surrogate process (column 3, line 67 - 
column 4, line 1, Held)). 

17. With regards to claim 37, Doyle teaches through Held, he computer-readable 
medium further comprising logic for choosing at least two segments of computer 
code from the plurality of segments of computer code, based on the information 
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in the list, which can be executed along with the computer program to process a 
type of data that the computer program is not designed to process 

(Doyle teaches a design that features a "list of applications," (column 15, 
line 14, Doyle). The list of applications allows an application to be selected to run 
along with the original program to provide an output from an input that the 
original program alone would be unable to provide as claimed. No limitation is 
given as to how many applications may be selected to run together; hence two or 
more may be selected claimed. In addition, since the list of applications Is 
initiated by the system, there must exist a service manager as claimed. 
However, such means are not expressly stated within Doyle's design. 

Held discloses a design allowing a second program or process to be 
called to assist a first program to perform a desired task on data (column 3, line 
65 - column 4, line 57, Held). Within the disclosure, Held states the existence of 
a service control manager (equivalent to the service manager) (column 4, line 16, 
Held). In addition. Held teaches how a surrogate process can be called from a 
first program without reference to an embedded link. Plus, Held discloses that 
multiple classes can be implemented by the same module (hence multiple 
behaviors/function/services can be made available and selected) (column 5, lines 
30-49, Held). 

Both Doyle and Held teach systems allowing one program to call upon 
another program to perform an operation on a piece of data. Hence, It would 
have been obvious to one skilled in the art, during the time of the invention, to 
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have combined the teachings of Doyle with those of Held, to provide a method 
for transparently executing code using a surrogate process (column 3, line 67 - 
column 4, line 1, Held)). 

18. With regards to claim 38, Doyle teaches through Held, the computer-readable 
medium, further comprising logic for linking the at least two segments of 
computer code in a specific order of execution to provide a desired output of data 
that the computer program is not designed to process when the at least two 
segments of computer code are executed along with the computer program 

(Doyle teaches a design that features a "list of applications," (column 15, 
line 14, Doyle). The list of applications allows an application to be selected to run 
along with the original program to provide an output from an input that the 
original program alone would be unable to provide as claimed. No limitation is 
given as to how many applications may be selected to run together; hence two or 
more may be selected claimed. Whenever multiple applications run together to 
produce a single output, it is inherent that they will perform in order as claimed. 
In addition, since the list of applications is initiated by the system, there must 
exist a service manager as claimed. However, such means are not expressly 
stated within Doyle's design. 

Held discloses a design allowing a second program or process to be 
called to assist a first program to perform a desired task on data (column 3, line 
65 - column 4, line 57, Held). Within the disclosure. Held states the existence of 
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a service control manager (equivalent to the service manager) (column 4, line 16, 
Held). In addition. Held teaches how a surrogate process can be called from a 
first program without reference to an embedded link. Plus, Held discloses that 
multiple classes can be implemented by the same module (hence multiple 
. behaviors/function/services can be made available and selected) (column 5, lines 
30-49, Held). 

Both Doyle and Held teach systems allowing one program to call 
upon another program to perform an operation on a piece of data. Hence, it 
would have been obvious to one skilled in the art, during the time of the 
invention, to have combined the teachings of Doyle with those of Held, to provide 
a method for transparently executing code using a surrogate process (column 3, 
line 67 - column 4, line 1 , Held)). 

19. With regards to claim 39, Doyle teaches through Held, the computer-readable 
medium, wherein the logic for creating a list that comprises information about a 
plurality of segments of computer code comprises: logic for identifying at least 
two segments of computer code that each comprise a registration code that 
indicates that they can be executed along with the computer program; and logic 
for generating a list comprising an identification code for each of the at least two 
segments of computer code that indicates that the at least two segments of 
computer code are available to be executed along with the computer program 
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(Doyle teaches a design that features a "list of applications," (column 15, 
line 14, Doyle). The list of applications allows an application to be selected to run 
along with the original program to provide an output from an input that the 
original program alone would be unable to provide as claimed. No limitation is 
given as to how many applications may be selected to run together; hence two or 
more may be selected claimed. Whenever multiple applications run together to 
produce a single output, it is inherent that they will perform in order as claimed. 
Furthermore, Doyle describes a design that has the means by which to identify 
the application to be launched from the local user client machine (column 1 5, 
lines 18-21, Doyle). In addition, since the list of applications is initiated by the 
system, there must exist a service manager as claimed. However, such means 
are not expressly stated within Doyle's design. 

Held discloses a design allowing a second program or process to be 
called to assist a first program to perform a desired task on data (column 3, line 
65 - column 4, line 57, Held). Within the disclosure, Held states the existence of 
a service control manager (equivalent to the service manager) (column 4, line 16, 
Held). In addition. Held teaches how a surrogate process can be called from a 
first program without reference to an embedded link. Plus, Held discloses that 
multiple classes can be implemented by the same module (hence multiple 
behaviors/function/services can be made available and selected) (column 5, lines 
30-49, Held). 
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Both Doyle and Held teach systems allowing one program to call 
upon another program to perform an operation on a piece of data. Hence, it 
would have been obvious to one skilled in the art, during the time of the 
invention, to have combined the teachings of Doyle with those of Held, to provide 
a method for transparently executing code using a surrogate process (column 3, 
line 67 - column 4, line 1 , Held)). 

20. With regards to claim 40, Doyle teaches through Held, computer-readable 
medium, further comprising logic for arranging the at least one segment of 
computer code and a data element, comprising the type of data that the 
computer program is not designed to process, into a function-data group; and 
logic for interfacing the function-data group to the computer program to enable 
the computer program to provide the output of the type of data that the computer 
program is not designed to process 

(Doyle teaches a design that features a "list of applications," (column 15, 
line 14, Doyle). The list of applications allows an application to be selected to run 
along with the original program to provide an output from an input that the 
original program alone would be unable to provide as claimed. No limitation is 
given as to how many applications may be selected to run together; hence two or 
more may be selected claimed. Whenever multiple applications run together to 
produce a single output, it is inherent that they will perform in order as claimed. 
Furthermore, for data to be processed, it typically is grouped together, for 
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instance within a data structure of some form. In addition, since the list of 
applications is initiated by the system, there must exist a service manager as 
claimed. However, such means are not expressly stated within Doyle's design. 

Held discloses a design allowing a second program or process to be 
called to assist a first program to perform a desired task on data (column 3, line 
65 - column 4, line 57, Held). Within the disclosure. Held states the existence of 
a service control manager (equivalent to the.service manager) (column 4, line 16, 
Held). In addition. Held teaches how a surrogate process can be called from a 
first program without reference to an embedded link. 

Both Doyle and Held teach systems allowing one program to call upon 
another program to perform an operation on a piece of data. Hence, it would 
have been obvious to one skilled in the art, during the time of the invention, to 
have combined the teachings of Doyle with those of Held, to provide a method 
for transparently executing code using a surrogate process (column 3, line 67 - 
column 4, line 1, Held)). 

21 .With regards to claims 41 , 44 and 47, Doyle teaches through Held, the method 
wherein each service container comprises a.data object, a code object, and a 
loader identification 

(Doyle teaches a design that features a "list of applications," (column 15, 
line 14, Doyle). The list of applications allows an application to be selected to run 
along with the original program to provide an output from an input that the 
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original program alone would be unable to provide as claimed. In addition, since 
the list of applications is initiated by the system, there must exist a service 
manager along with reference pointers as claimed. However, such means are 
not expressly stated within Doyle's design. 

Held discloses a design allowing a second program or process to be 
called to assist a first program to perform a desired task on data (column 3, line 
65 - column 4, line 57, Held). Within the disclosure. Held states the existence of 
a service control manager (equivalent to the service manager) (column 4, line 16, 
Held). In addition, Held teaches how a surrogate process can be called from a 
first program without reference to an embedded link. 

Both Doyle and Held teach systems allowing one program to call upon 
another program to perform an operation on a piece of data. Hence, it would 
have been obvious to one skilled in the art, during the time of the invention, to 
have combined the teachings of Doyle with those of Held, to provide a method 
for transparently executing code using a surrogate process (column 3, line 67 - 
column 4, line 1, Held)). 

22. With regards to claims 42, 45 and 48, Doyle teaches through Held, the method 
wherein each code object references at least one service object 

(Doyle teaches a design that features a "list of applications," (column 15, 
line 14, Doyle). The list of applications allows an application to be selected to run 
along with the original program to provide an output from an input that the 
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original program alone would be unable to provide as claimed. In addition, since 
the list of applications is initiated by the system, there must exist a service 
manager along with reference pointers as claimed. However, such means are 
not expressly stated within Doyle's design. 

Held discloses a design allowing a second program or process to be 
called to assist a first program to perform a desired task on data (column 3, line 
65 - column 4, line 57, Held). Within the disclosure, Held states the existence of 
a service control manager (equivalent to the service manager) (column 4, line 16, 
Held). In addition. Held teaches how a surrogate process can be called from a 
first program without reference to an embedded link. 

Both Doyle and Held teach systems allowing one program to call upon 
another program to perform an operation on a piece of data. Hence, it would 
have been obvious to one skilled in the art, during the time of the invention, to 
have combined the teachings of Doyle with those of Held, to provide a method 
for transparently executing code using a surrogate process (column 3, line 67 - 
column 4, line 1, Held)). 

23. With regards to claims 43, 46 and 49, Doyle teaches through Held, a method 
wherein each service object is stored in a cache, separate from each service 
container 

(Doyle teaches a design that features a "list of applications," (column 15, 
line 14, Doyle). The list of applications allows an application to be selected to run 
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along with the original program to provide an output from an input that the 
original program alone would be unable to provide as claimed. In addition, since 
the list of applications is initiated by the system, there must exist a service 
manager along with reference pointers as claimed. However, such means are 
not expressly stated within Doyle's design. 

Held discloses a design allowing a second program or process to be 
called to assist a first program to perform a desired task on data (column 3, line 
65 - column 4, line 57, Held). Within the disclosure, Held states the existence of 
a service control manager (equivalent to the.service manager) (column 4, line 16, 
Held). In addition, Held teaches how a surrogate process can be called from a 
first program without reference to an embedded link. Plus, Held discloses that 
means for caching exist within the design (column 16, line 62 - column 17, line 5, 
Held). 

Both Doyle and Held teach systems allowing one program to call upon 
another program to perform an operation on a piece of data. Hence, it would 
have been obvious to one skilled in the art, during the time of the invention, to 
have combined the teachings of Doyle with those of Held, to provide a method 
for transparently executing code using a surrogate process (column 3, line 67 - 
column 4, line 1, Held)). 

24. With regards to claim 50, Doyle teaches through Held, a method for accessing; 
multiple types of electronic content from a program, comprising the steps of: 
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defining a plurality of service containers accessible to the program, each service 
container corresponding to a specific function, each service container including: 
a data object, such that each data object includes data required to enable the 
specific function corresponding to the service container to be achieved; a code 
object, each code object referencing at least one segment of programming code 
stored separately from the service container, such that the at least one segment 
of programming code referenced by the code object includes programming code 
required to enable the specific function corresponding to the service container to 
be achieved; and a loader identification, the loader identification providing the 
program with information required to load the segment of programming code 
referenced by the code object; requesting an input to be processed to obtain an 
output; identifying one of the plurality of service containers whose corresponding 
specific function is able to process the input; parsing the service container thus 
identified, to determine: data required to enable the specific function 
corresponding to the service container to be achieved; an identity of the at least 
one segment of programming code required to enable the specific function 
corresponding to the service container to be achieved; and information required 
to load each segment of programming code referenced by the code object; 
retrieving the at least one segment of programming code required to enable the 
specific function corresponding to the service, container to be achieved; and 
executing the at least one segment of computer code under the control of the 
computer program to process the input and obtain the output, wherein said 
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computer program is not directed to the at least one segment of computer code 
by any embedded link referenced by said computer program 

(Doyle teaches a design that features a "list of applications," (column 15, 
line 14, Doyle). The list of applications allows an application to be selected to run 
along with the original program to provide an output from an input that the 
original program alone would be unable to provide as claimed. In addition, since 
the list of applications is initiated by the system, there must exist a service 
manager as claimed. However, such means are not expressly stated within 
Doyle's design. 

Held discloses a design allowing a second program or process to be 
called to assist a first program to perform a desired task on data (column 3, line 
65 - column 4, line 57, Held). Within the disclosure, Held states the existence of 
a service control manager (equivalent to the service manager) (column 4, line 16, 
Held). In addition, Held teaches how a surrogate process can be called from a 
first program without reference to an embedded link. 

Both Doyle and Held teach systems allowing one program to call upon 
another program to perform an operation on a piece of data. Hence, it would 
have been obvious to one skilled in the art, during the time of the invention, to 
have combined the teachings of Doyle with those of Held, to provide a method 
for transparently executing code using a surrogate process (column 3, line 67 - 
column 4, line 1, Held)). 
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Response to Remarks 

The amendment received on March 7, 2005 has been carefully evaluated but is 
not deemed fully persuasive. First, in response to the amended claims a new prior art 
(Held) has been supplied to illustrate the existence of designs allowing one program to 
call upon another program or process without the use of embedded links. 

Secondly, the Held prior art also addresses the applicant's representative's 
concerns over the service manager. While the examiner does not feel that the Pratt 
prior art previously applied for the service manager trait is insufficient. The fact that the 
amendment necessitated a new search and a new prior art, and that the new prior art 
features a service manager literally; the Pratt prior art has been replaced with the Held 
prior art. The Held prior art illustrates the existence of service managers within designs 
allowing one program to call upon another program or process. 

Conclusion 

Applicant's amendment necessitated the new ground(s) of rejection presented in 
this Office action. Accordingly, THIS ACTION IS MADE FINAL. See MPEP 
§ 706,07(a). Applicant is reminded of the extension of time policy as set forth in 37 
CFR 1.136(a). 

A shortened statutory period for reply to this final action is set to expire THREE 
MONTHS from the mailing date of this action. In the event a first reply is filed within 
TWO MONTHS of the mailing date of this final action and the advisory action is not 
mailed until after the end of the THREE-MONTH shortened statutory period, then the 
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shortened statutory period will expire on the date the advisory action is mailed, and any 
extension fee pursuant to 37 CFR 1 .136(a) will be calculated from the mailing date of 
the advisory action. In no event, however, will the statutory period for reply expire later 
than SIX MONTHS from the date of this final action. 

Any inquiry concerning this communication or earlier communications from the 
examiner should be directed to Azizul Choudhury whose telephone number is (571) 
272-3909. The examiner can normally be reached on M-F. 

If attempts to reach the examiner by telephone are unsuccessful, the examiner's 
supervisor, Valencia Martin-Wallace can be reached on (571) 272-6159. The fax phone 
number for the organization where this application or proceeding is assigned is 703- 
872-9306. 

Information regarding the status of an application may be obtained from the 
Patent Application Information Retrieval (PAIR) system. Status information for 
published applications may be obtained from either Private PAIR or Public PAIR. 
Status information for unpublished applications is available through Private PAIR only. 
For more information about the PAIR system, see http://pair-direct.uspto.gov. Should 
you have questions on access to the Private PAIR system, contact the Electronic 
Business Center (EBC) at 866-217-9197 (toll-free). 
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